$(function () {
    var layer = layui.layer;
    initCate();

    function initCate() {
        $.ajax({
            method: 'get',
            url: '/my/article/cates',
            success: function (res) {
                if (res.status !== 0) {
                    return layer.msg(res.message, {
                        icon: 5
                    });
                }
                var htmlStr = template('tpl-cate', res);
                $('[name=cate_id]').html(htmlStr);
                //重新渲染表单
                layui.form.render();
            }
        })
    }
    //初始化
    initEditor()
    //图片实现的步骤
    var $image = $('#image')
    var options = {
        aspectRatio: 400 / 280,
        preview: '.img-preview'
    }
    $image.cropper(options)
    //单击选择封面按钮弹出文件选择框
    $('#btnChooseImage').on('click', function () {
        $('#coverFile').click();
    })
    //当用户选择图片，更换裁剪区
    $('#coverFile').on('change', function () {
        var fileList = $(this)[0].files;
        if (fileList.length === 0) {
            return layer.msg('请选择文件', {
                icon: 5
            });
        }
        var file = fileList[0];
        var newImgURL = URL.createObjectURL(file);
        $image
            .cropper('destroy') // 销毁旧的裁剪区域
            .attr('src', newImgURL) // 重新设置图片路径
            .cropper(options) // 重新初始化裁剪区域
    })
    //准备文章状态
    var state = '已发布';
    $('#btnSave2').on('click', function () {
        state = '草稿';
    })
    $('#form-pub').on('submit', function (e) {
        e.preventDefault();
        var fd = new FormData($(this)[0]);
        fd.append('state', state)
        // fd.forEach(item => {
        //     console.log(item);
        // })
        $image
            .cropper('getCroppedCanvas', {
                width: 400,
                height: 280
            })
            .toBlob(function (blob) {
                //追加到fd中
                fd.append('cover_img', blob);
                publishArticle(fd);
            })
    })

    function publishArticle(fd) {
        $.ajax({
            method: 'post',
            url: '/my/article/add',
            data: fd,
            contentType: false,
            processData: false,
            success: function (res) {
                if (res.status !== 0) {
                    return layer.msg(res.message, {
                        icon: 5
                    })
                }
                layer.msg(res.message, {
                    icon: 6
                }, function () {
                    window.parent.document.querySelector('#articleList').click();
                })

            }
        })
    }
})